Двозв’язні списки

Інформація про навчальний заклад

ВУЗ:
Інші
Інститут:
Не вказано
Факультет:
КН
Кафедра:
Не вказано

Інформація про роботу

Рік:
2011
Тип роботи:
Лабораторна робота
Предмет:
Програмування

Частина тексту файла

Міністерство освіти і науки України Хмельницький національний університет Кафедра системного програмування Лабораторна робота №2 з програмування на тему: «Двозв’язні списки» Лабораторна робота №2 Тема: двозв'язні списки. Мета: навчитися програмувати з використанням вказівників та динамічних змінних, створювати та опрацьовувати двозв'язні списки. Завдання Дано «покажчик» на один з елементів непустого двозв'язного списку. Видалити зі списку даний елемент і вивести два «покажчика»: на елемент, що передує вилученому і на елемент, що іде за вилученим (один або обидва цих елементи можуть бути відсутніми; для відсутніх елементів виводити nil). Після видалення елемента зі списку звільнити пам'ять, займану цим елементом. uses crt; type vkaz=^spysok; spysok=record num:integer; next, last:vkaz end; procedure add(var a,head,tail:vkaz; D:integer); begin if a=nil then begin new(a); a^.next:=nil; a^.last:=nil; head:=a; end else begin new(a^.next); a^.next^.last:=a; a:=a^.next; a^.next:=nil; end; a^.num:=D; tail:=a; end; procedure create(var a,head,tail:vkaz; var n:integer); var i,D:integer; begin repeat write('vvedit kilkist chysel: '); readln(n) until n>0; for i:=1 to n do begin add(a,head,tail,random(50)); write(a^.num,' '); end; writeln; end; procedure Search(var a:vkaz; head:vkaz; var D:integer); var p:boolean; begin repeat write('vvedit element dlja vydalennja: '); readln(D); a:=head; while (a<>nil) and (d<>a^.num) do a:=a^.next; if a^.num=D then p:=true until p; end; procedure DelEl(var a:vkaz; head:vkaz); var temp:vkaz; D:integer; begin search(a,head,D); if (a^.last=nil) and (a^.next=nil) then begin writeln('poperednij element=NIL'); writeln('nastupnyj element=NIL'); temp:=a; a:=nil; dispose(temp); end else begin if (a^.last=nil) or (a^.next=nil) then begin if a^.last=nil then begin writeln('poperednij element=NIL'); writeln('nastupnyj element: ',seg(a^.next^),ofs(a^.next^)); temp:=a; a^.next^.last:=nil; dispose(temp); end; if a^.next=nil then begin writeln('nastupnyj element=NIL'); writeln('poperednij element: ',seg(a^.last^),ofs(a^.last^)); temp:=a; a^.last^.next:=nil; dispose(temp); end; end else begin writeln('poperednij element: ',seg(a^.last^),ofs(a^.last^)); writeln('nastupnyj element: ',seg(a^.next^),ofs(a^.next^)); temp:=a; a^.last^.next:=a^.next; a^.next^.last:=a^.last; dispose(temp); end; a:=head; while a<>nil do begin write(a^.num,' '); a:=a^.next; end; ...
Антиботан аватар за замовчуванням

28.03.2013 22:03

Коментарі

Ви не можете залишити коментар. Для цього, будь ласка, увійдіть або зареєструйтесь.

Завантаження файлу

Якщо Ви маєте на своєму комп'ютері файли, пов'язані з навчанням( розрахункові, лабораторні, практичні, контрольні роботи та інше...), і Вам не шкода ними поділитись - то скористайтесь формою для завантаження файлу, попередньо заархівувавши все в архів .rar або .zip розміром до 100мб, і до нього невдовзі отримають доступ студенти всієї України! Ви отримаєте грошову винагороду в кінці місяця, якщо станете одним з трьох переможців!
Стань активним учасником руху antibotan!
Поділись актуальною інформацією,
і отримай привілеї у користуванні архівом! Детальніше

Оголошення від адміністратора

Антиботан аватар за замовчуванням

пропонує роботу

Admin

26.02.2019 12:38

Привіт усім учасникам нашого порталу! Хороші новини - з‘явилась можливість кожному заробити на своїх знаннях та вміннях. Тепер Ви можете продавати свої роботи на сайті заробляючи кошти, рейтинг і довіру користувачів. Потрібно завантажити роботу, вказати ціну і додати один інформативний скріншот з деякими частинами виконаних завдань. Навіть одна якісна і всім необхідна робота може продатися сотні разів. «Головою заробляти» продуктивніше ніж руками! :-)

Новини